// 引入一个包
const path =require('path');

//引入HTML插件
const HTMLWebpavkOlugin=require('html-webpack-plugin');
//引入clean插件
const {CleanWebpackPlugin} = require('clean-webpack-plugin');
//webpack中的所有配置信息都应该写在module.exports中
module.exports={
    //指定入口文件
    entry:"./src/index.ts",
    //指定打包文件所在目录
    output:{
        //指定打包文件的目录
        path:path.resolve(__dirname,'dist'),
        //打包后文件名
        filename:"bundle.js",
        //告诉webpack打包时不使用箭头函数
        environment:{
            arrowFunction:false
        }
    },
    //指定打包时要使用的模块
    module:{
        //指定要加载规则
        rules:[
            {
                //test指定规则生效的文件
                test:/\.ts$/,
                //指定要使用的loader
                use:[
                    //配置babel
                    {
                        //指定加载器
                        loader:"babel-loader",
                        //设置babel
                        options:{
                            //设置预定义的环境
                            preset:[
                                [
                                    //指定环境的插件
                                    "@babel/preset-env",
                                    //配置信息
                                    {
                                        //指定要兼容的目标浏览器
                                        "targets":{
                                            "chrome":88
                                        },
                                        //指定corejs版本
                                        "corejs":"3",
                                        //使用corejs的方法:"usage"表示按需加载
                                        "useBuiltIns":"usage"
                                    }
                                ]
                            ]
                        }
                    },
                    'ts-loader'
                ],
                //指定要派出的文件
                exclude:/node_modules/
            }
        ]
    },
    //配置webpack插件
    plugins:[
        new CleanWebpackPlugin(),
        new HTMLWebpavkOlugin({
            //title: "自定义文件"
            template:"./src/index.html"
        }),

    ],
    //用来设置引用模块
    resolve:{
        extensions:['.ts','.js']
    }
};